golang 您所在的位置:网站首页 golang 切片并发安全 golang

golang

2023-03-13 19:16| 来源: 网络整理| 查看: 265

golang_并发安全: slice和map并发不安全及解决方法 转载

mb5fd8698f60f87 2021-09-09 10:55:00

文章标签 i++ 加锁 数据 解决方法 线程安全 文章分类 代码人生

golang_并发安全: slice和map并发不安全及解决方法 Grayan · 2020-07-21 15:32:48 · 1771 次点击 · 预计阅读时间 1 分钟 · 不到1分钟之前 开始浏览     这是一个创建于 2020-07-21 15:32:48 的文章,其中的信息可能已经有所发展或是发生改变。 并发安全

并发安全也叫线程安全,在并发中出现了数据的丢失,称为并发不安全

map和slice都是并发不安全的

切片并发不安全

场景: 10000个协程同时添加切片

var s []int func appendValue(i int) { s = append(s, i) } func main() { for i := 0; i < 10000; i++ { //10000个协程同时添加切片 go appendValue(i) } for i, v := range s { //同时打印索引和值 fmt.Println(i, ":", v) } }

Output:

golang_并发安全: slice和map并发不安全及解决方法_线程安全

没有到9999,说明有数据丢失

解决方法: 加锁

var s []int var lock sync.Mutex //互斥锁 func appendValue(i int) { lock.Lock() //加锁 s = append(s, i) lock.Unlock() //解锁 } func main() { for i := 0; i < 10000; i++ { go appendValue(i) } //sort.Ints(s) //给切片排序,先排完序再打印,和下面一句效果相同 time.Sleep(time.Second) //间隔1s再打印,防止一边插入数据一边打印时数据乱序 for i, v := range s { fmt.Println(i, ":", v) } }

总结: slice在并发执行中不会报错,但是数据会丢失

map并发不安全

场景: 2个协程同时读和写

func main() { m := make(map[int]int) go func() { //开一个协程写map for i := 0; i < 10000; i++ { m[i] = i } }() go func() { //开一个协程读map for i := 0; i < 10000; i++ { fmt.Println(m[i]) } }() //time.Sleep(time.Second * 20) for { ; } }

Output:

golang_并发安全: slice和map并发不安全及解决方法_数据_02

解决方法:尽量不要做map的并发,如果用并发要加锁,保证map的操作要么读,要么写。

var lock sync.Mutex func main() { m:=make(map[int]int) go func() { //开一个协程写map for i:=0;i 收藏 评论 分享 举报

上一篇:django连接和游标

下一篇:nginx 直接在配置文章中设置日志分割



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有